home *** CD-ROM | disk | FTP | other *** search
/ Linux Cubed Series 4: GNU Archives / Linux Cubed Series 4 - GNU Archives.iso / gnu / termutil.0 / termutil / termutils-2.0 / error.c < prev    next >
Encoding:
C/C++ Source or Header  |  1995-11-30  |  3.2 KB  |  127 lines

  1. /* error.c -- error handler for noninteractive utilities
  2.    Copyright (C) 1990, 91, 92, 93, 94, 95 Free Software Foundation, Inc.
  3.  
  4.    This program is free software; you can redistribute it and/or modify
  5.    it under the terms of the GNU General Public License as published by
  6.    the Free Software Foundation; either version 2, or (at your option)
  7.    any later version.
  8.  
  9.    This program is distributed in the hope that it will be useful,
  10.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  11.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12.    GNU General Public License for more details.
  13.  
  14.    You should have received a copy of the GNU General Public License
  15.    along with this program; if not, write to the Free Software
  16.    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
  17.  
  18. /* Written by David MacKenzie <djm@gnu.ai.mit.edu>.  */
  19.  
  20. #ifdef HAVE_CONFIG_H
  21. #include <config.h>
  22. #endif
  23.  
  24. #include <stdio.h>
  25.  
  26. #if HAVE_VPRINTF || HAVE_DOPRNT
  27. # if __STDC__
  28. #  include <stdarg.h>
  29. #  define VA_START(args, lastarg) va_start(args, lastarg)
  30. # else
  31. #  include <varargs.h>
  32. #  define VA_START(args, lastarg) va_start(args)
  33. # endif
  34. #else
  35. # define va_alist a1, a2, a3, a4, a5, a6, a7, a8
  36. # define va_dcl char *a1, *a2, *a3, *a4, *a5, *a6, *a7, *a8;
  37. #endif
  38.  
  39. #if STDC_HEADERS
  40. # include <stdlib.h>
  41. # include <string.h>
  42. #else
  43. void exit ();
  44. #endif
  45.  
  46. /* This variable is incremented each time `error' is called.  */
  47. unsigned int error_message_count;
  48.  
  49. /* If NULL, error will flush stdout, then print on stderr the program
  50.    name, a colon and a space.  Otherwise, error will call this
  51.    function without parameters instead.  */
  52. void (*error_print_progname) () = NULL;
  53.  
  54. /* The calling program should define program_name and set it to the
  55.    name of the executing program.  */
  56. extern char *program_name;
  57.  
  58. #if HAVE_STRERROR
  59. # ifndef strerror        /* On some systems, strerror is a macro */
  60. char *strerror ();
  61. # endif
  62. #else
  63. static char *
  64. private_strerror (errnum)
  65.      int errnum;
  66. {
  67.   extern char *sys_errlist[];
  68.   extern int sys_nerr;
  69.  
  70.   if (errnum > 0 && errnum <= sys_nerr)
  71.     return sys_errlist[errnum];
  72.   return "Unknown system error";
  73. }
  74. #define strerror private_strerror
  75. #endif
  76.  
  77. /* Print the program name and error message MESSAGE, which is a printf-style
  78.    format string with optional args.
  79.    If ERRNUM is nonzero, print its corresponding system error message.
  80.    Exit with status STATUS if it is nonzero.  */
  81. /* VARARGS */
  82.  
  83. void
  84. #if defined(VA_START) && __STDC__
  85. error (int status, int errnum, const char *message, ...)
  86. #else
  87. error (status, errnum, message, va_alist)
  88.      int status;
  89.      int errnum;
  90.      char *message;
  91.      va_dcl
  92. #endif
  93. {
  94. #ifdef VA_START
  95.   va_list args;
  96. #endif
  97.  
  98.   if (error_print_progname)
  99.     (*error_print_progname) ();
  100.   else
  101.     {
  102.       fflush (stdout);
  103.       fprintf (stderr, "%s: ", program_name);
  104.     }
  105.  
  106. #ifdef VA_START
  107.   VA_START (args, message);
  108. # if HAVE_VPRINTF
  109.   vfprintf (stderr, message, args);
  110. # else
  111.   _doprnt (message, args, stderr);
  112. # endif
  113.   va_end (args);
  114. #else
  115.   fprintf (stderr, message, a1, a2, a3, a4, a5, a6, a7, a8);
  116. #endif
  117.  
  118.   ++error_message_count;
  119.  
  120.   if (errnum)
  121.     fprintf (stderr, ": %s", strerror (errnum));
  122.   putc ('\n', stderr);
  123.   fflush (stderr);
  124.   if (status)
  125.     exit (status);
  126. }
  127.